草庐IT

csv - 总结csv的内容

全部标签

Ruby 1.9.3 - CSV.table 如何知道 CSV 文件中是否没有 header ?

我一直在用CSV.table做一些测试。我有两个几乎相同的小CSV文件,但其中一个缺少标题行。当我对带有标题行的CSV文件运行CSV.table时,一切都按预期进行。当我针对没有标题行的CSV文件运行它时,我得到:NoMethodError:undefinedmethod`encode'fornil:NilClass我用不同类型的数据、不同类型的header尝试了这个,并得到了相同的结果。我很好奇CSV.table的魔力。如果我使用CSV.parse并将标题设置为true,那么无论如何它总是使第一行成为标题。所以,我一直在使用CSV.table来检查导入的CSV文件是否有标题行,但我对

ruby - 如何将 CSV 转换为 Excel?

Ruby中是否有任何插件可以将CSV文件转换为Excel。我几乎没用谷歌搜索,但我发现的只是将Excel文件转换为CSV。我知道一些我可以稍微调整并用于将Excel转换为CSV的gem,但我需要知道以前是否有人这样做过。 最佳答案 根据thispost,spreadsheetgem是一种可能性。看起来这是一个非常受欢迎的gem。看看这个。例子:book=Spreadsheet::Workbook.newsheet1=book.create_worksheetheader_format=Spreadsheet::Format.new(

ruby - 如何使用 Rack 为特定文件设置内容类型?

我想让Rack提供具有特定内容类型的特定文件。它是一个.htc文件,需要作为text/x-component提供,以便IE识别它。在apache中我会这样做AddTypetext/x-component.htc如何使用Rack实现这一目标?目前该文件由Rack::Static提供,但我没有找到设置内容类型的选项。 最佳答案 您可以像这样更新您的config/initializers/mime_types.rb:#Besuretorestartyourserverwhenyoumodifythisfile.#Addnewmimetyp

ruby-on-rails - 如何在 Rails 助手中将内容包装在 html 中

我想在Rails3助手中用HTML包装一些内容,这样在我看来我可以这样做:我有一个如下所示的辅助方法:defrounded_box(&block)str="str"rawstrend我现在使用它的方式返回正确包装在HTML字符串中的内容,但不会在呈现rounded_boxblock中的任何erb之前返回(例如,在这种情况下,target.text呈现两次,一次包装,一次不包装)。有更好的方法吗?为简单起见,我想避免使用content_tag,但如果这是我能做到的唯一/最佳方式。 最佳答案 在block上调用capture而不是yie

ruby-on-rails - 如何获取给定内容类型的默认扩展名?

给定变量content_type="application/pdf"也可以包含任何其他mime类型。如何获取内容类型的默认扩展名?我目前有两个解决方案,看起来很“复杂”。破解字符串content_type.split("/")[1]使用MIME::类型require'mime/types'MIME::Types[content_type].first.extensions.first有没有更好的解决方案? 最佳答案 您只需使用ruby​​的Hash.invert方法即可。Thisanswer展示了如何做:Rack::Mimehast

ruby-on-rails - 事件管理员 CSV 导出自定义查询范围

我正在使用活跃的管理员导出CSV选项。它返回与特定表相关的所有值。我只想要特定月份的报告。有人能帮忙吗? 最佳答案 您可以编写自己的csv导出器collection_action:download_report,:method=>:getdousers=User.where('created_at>=?',Date.today-1.month)csv=CSV.generate(encoding:'Windows-1251')do|csv|#addheaderscsv:download_report))endindex:downloa

ruby-on-rails - 为什么 String#gsub 的内容加倍?

s="#main='quotes's.gsub"'","\\'"#=>"#main=quotes'quotes"这似乎是错误的,我希望得到"#main=\\'quotes\\'"当我不使用转义字符时,它会按预期工作。s.gsub"'","*"#=>"#main=*quotes*"所以一定有转义的事情。使用ruby1.9.2p290我需要用反斜杠和引号替换单引号。更多的不一致:"\\'".length#=>2"\\*".length#=>2#Asexpected"'".gsub("'","\\*").length#=>2"'a'".gsub("'","\\*")#=>"\\*a\\*"(

Ruby 1.9.2 导出 CSV 字符串而不生成文件

我只是无法在“写作”下获得“到字符串”示例exampleinthedocumentation完全可以工作。ruby-v返回:ruby1.9.2p290(2011-07-09修订版32553)[x86_64-darwin10.8.0]我无法使用的文档示例在这里:csv_string=CSV.generatedo|csv|csv我得到的错误是:wrongnumberofarguments(0for1)看来我在文档中遗漏了一个参数here它指出:ThismethodwrapsaStringyouprovide,oranemptydefaultString但是当我传入一个空字符串时,会出现以下

ruby - 在 Ruby CSV 中,如何将空白 , 而不是 ,""写入文件?

Ruby1.9版本的csvheader%w[firstsecondthird]data=["columnone",,"columnthree"]CSV.open("myfile.csv","w")do|csv|csv在这个简单的示例中,数据数组中的空中间,,会导致错误,但如果使用空引号,"",则不会出现错误,并且会创建CSV文件。但是我想让CSV文件没有空的引号段。具体来说,如何生成不带引号的CSV文件的空白部分?数据可以是空变量,但它仍然应该写逗号。 最佳答案 使用data=["columnone",nil,"columnthre

Ruby:如何生成具有 Excel 友好编码的 CSV 文件

我正在生成CSV文件,这些文件生成后需要在Excel中打开和查看。Excel似乎需要与UTF-8不同的编码。这是我的配置和生成代码:csv_config={col_sep:";",row_sep:"\n",encoding:Encoding::UTF_8}csv_string=CSV.generate(csv_config)do|csv|csv在Excel中打开时,特殊字符显示不正确:TextaTextbTextæTextøTextÃ¥知道如何确保正确编码吗? 最佳答案 如果Excel具有BOM,则它可以理解UTF-8CSV。可